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(54) Atotraa Title 

Intemat baaed printing using a wab browser 

(57) A printer oonneclMty component. cooperaMe with a web browser to connect a workstation to a printer 
comprises means to read a configuration file, where the file comprises data defining a connection to the 
printer, accessed from the browser, end means response to the data to enable the workstation to connect to 
the printer. The component may be a helper application or a brevier plug-In. The file may comprises fields 
indicating the printer's location, a protocol for connecting to the printer and a printer driver. The component 
may also comprise means iZZM) for Installing the protocol and driver If they are not Installed on the 
workstation, or If the drh^er which Is Installed is not the latest version. 
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The present Invention relates to a eoopcment for providing printer 
connectivity and a method for connecting to a printer. 

Since the Introduction of laptop computBra and Personal Digital 
Assistants (PDA), conputer users have become ever more nbblle. Laptop 
computers, in particular, have become ever more powerful and compact, and 
both the computer and Its accessories fit neatly into a briefcase. 
However, It Is often not practical for a mobile user to also carry a 
printer. Its leads and paper, and so such users are faced with the 
problem of how to print. 

Even when a mobile user arrives at a site where printers may be 
available, it can be frustrating for the user to connect to the printer 
The user must find out what printers are available, if printers are 
shared • find our their network address, locate and install appropriate 
drivers, and in some eases get LMt access to connect to a print server. 

There is also another type of user who may wish to print material 
without direct access to a printer. Digital television viewers will 
increasingly be able to access Internet services through set- top boxes 
connected to their television and win from time to time need to print 
infonnatlon. While the television may not be connected to a printer, such 
users nay nonetheless wish to print out certain pages or forms which they 
may need to complete. 

The present Invention meets the printing re<iuirement of the above 
types of users by providing a component for providing printer 
connectivity as claimed in the claim l and a method of connecting a 
workstation to a printer as claimed in claim 12. 

Embodiments of the Invention will now be described with reference 
to the accompanying drawings. In which: 

Figure 1 Is a schematic view of a network including a printer 
connectivity component according to the Invention; and 

Figure 2 illustrates the operation of the printer connectivity 
component of Figure 1. 

The operation of Internet browsers such as Communicator from 
Netscape Corporation or Internet Explorer from Microsoft Corporation is 
well known. Such browsers associate either a plug-in program to process 
internet objects within the browser or designate a stand alone 
application to launch on selection of an internet object. Helper 
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applications are usually cbnventional type applications written in, for 
exan(ple# the Progrananing language and must be present on tlxe browser 
computer to allow their associated internet objects to be processed. 
While the preferred enibodiment is described in terms of a stand alone 
helper application, it will be seen that the invention is equally 
applicable to a plug- in program and the term "helper" is used in the 
specification to cover both types of pro9ran or any other program 
downloaded or installed once by a user to enable a browser to deal with 
objects of a given type. 



Helpers are conventionally used, for example, when a html page 
being viewed on a browser includes a linX to a multimedia file such as a 
.mp9 file, and the user cliclcs on this link. The browser can either 
instantiate a plug- in which plays the file within the browser or launch 
15 the helper application associated with files of the .mpg extension to 

play the file outside the browser. 

Referring now to Figure 1, the invention on the other hand uses a 
helper 10 installed on a client computer 12 connected to a web server 14 
20 to allow a user to select from one or nore printer object links 18 

displayed on a web page 16 downloaded from the web server and have their 
wor)cstation automatically enabled to print to that printer regardless of 
where the* client computer 12 or the printer 20, 22 are located. 

25 It will be seen from the following description that while the 

helper 10 according to the present enibodiment is described in terms of 
the Windows operating system from Microsoft Corporation, the invention is 
operable with other operating systems such as OS/2 from IBM Corporation 
to configure a client machine to connect to a selected printer. 

30 

The preferred embodiment achieves this by allowing the user to 
download the helper application 10 appropriate to their operating system 
and the user's language onto their workstation from the Internet, 
although the helper may be obtained from any suitable source such as a 
35 tAN server or installation diskette. The helper is used to deal with 

files 24 that have a unioue file extension of, for example, .alx. Each 
printer 20, 22 has one such unique .alx file associated with it, and each 
*alx file 24 is referenced in a web page link IB so that when the page is 
displayed on a client browser, it can be selected by a user. 

40 

The web page for selecting a printer will usually also have a link 
26 enabling a user to download and install the helper 10 from the server * 
onto the client machine 12 to allow first time users to operate the 
system, once the helper has been installed and the browser is configured 
45 in a conventional manner to associate the helper with files of the .alx 
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type, the user can select from any one of the printer links 18 displayed 
on the web page. 

Referring now to Figure 2. on selecting a printer, step 28. the 
helper is instantiated and passed the .alx file across the internet with 
its data becoming available for the helper to read. It is the Interaction 
Of the helper and the .alx file unique to a printer which enables the 
helper to ascertain: what protocol the printer is using, for exaaple. 
NEIBBOI for connection to a printer 22 on the sane LM» as the client or 
TCPIP for connection to a printer 20 across the Internet; what printer 
driver the printer retpiires; and any other configuration details that may 
be required. Armed with this information the helper lo deletes the alx 
file frcn the workstation and sets about the task of automatically 
installing the protocol and/or printer driver and connecting to the 
15 printer. 

It will be seen that protocols and printer drivers can be installed 
by any nuirtber of conventional means. Microsoft platforms supply a library 
which can be linked into the helper to allow the helper to make direct 
20 API calls to check for currently Installed protocols and drivers and to 

install a protocol or printer driver. For other platforms, the helper may 
have to cause macros to execute or write flies directly to disk to 
Install a protocol. 

" -"^ ^^le varies according to the protocol and driver etc that 

the printer as displayed to the user to choose from Is using. Table «l is 
a portion of typical example of a .alx file for a tcpip based printer in 
general, the -.alx file includes a core portion beginning with a label 
(DATA] Which i 
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provides the helper with platform Independent Information, such as. 
the address of the printer given In the 'args" field, and the 
protocol given in the "protocol f field; 

tells the helper where in the .alx file to look for its platform's 
parameters, eg windows 98 driver information is found at label 
IXSH Network Printer 17J pointed to by the 'wlnsedrv- field; 

tells the helper where to look for data files by providing one or 
more sets of 3 fields -site-, -pass" ana -name-. These fields 
contain the necessary information for the helper to know frcai where 
to get new versions of helper, protocol drivers and/or printer 
drivers according to the location of the user, and 



gives the helper the dates for the latest version of driver in the 
"...drvdste" fields for each supported platform, so that the helper 
can checX if locally installed drivers versions are up to date. 

The remainder of the .alx file contains one or more platform 
dependent portions^ each labelled vith the contents of their respective 
"...drv" fields in the IDATA) portion. Table #1 only shows such a portion 
for a Windows 98 printer object using the "IBM Network Printer 17" print 
driver, but in a complete .alx file, similar portions would follow for 
OS/2, windows 3.1, and windows NT platforms indicated in the [DATA] 
portion. Nonetheless, the exact information contained in these sections 
will vary for every single printer driver and operating system such is 
the complexity of modem print drivers. 

In the present exaa^le, the portion of Table 91 following the 
(IBH Network Printer 17] label includes a list of fields that need to be 
passed to the Windows addprinterdriver 0 function to install the 
llBH Network Printer 17] on a windows platform. This function can be 
called once the required printer driver files have been placed in the 
correct directory, eg windows Xsys ten for windows '9B, 

In brief the fields ares 

#drvfile which gives the helper the name of the driver file to download. 
l)ie driver for eg. an IBH Network Printer 17 may require several files 
(typically around 30) and so these are prepackaged on the software 
repository server 14 into a single self extracting file, in this case, 
IBM9S.exe. This makes for a very fast download cutting down on network 
traffic and the time it takes to manually install a driver. 

tversion which in the present example is simply a parameter passed to the 
addprinterdriver <) function. The helper actually determines the printer 
driver version by looking at specific file dates on the local wrkstation 
and comparing these to the contents of the appropriate **. . .drvdate" 
field. 

Itdrivemame, the name of the driver, which is again passed to the 
addprinterdriver () function. The helper can determine if the printer is 
installed by calling another API function listing installed printer 
drivers and searching for the driver name in the returned list. 

ttfilelist which is a list of files on v^ich the driver depends. 

tenvlronment which the operating system environment eg. windows 98. 
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•dataflle. dconflgflle, Idrivexpath, «lxeXpfUe. tooaltor. «de£aulttype 
wbich are all downloaded driver configuration files passed to 
addprinterdrlverO . 

in more general tenns the helper operates as follows; 

A. Check the -helperdate- field to determine that the* helper 
application itself is up to date, step 30. if not. the user is prompted 
to update the helper, by using an IP connection to download a new version 
froa the web server 14 (or any other suitable server). i« the example of 
Table #1, only one IP address for a server 14 is given in the -site- 
field and a password and usemane for the site are also provided in the 
following fields. If nore than one such IP address were provided, then 
the helper could determine which server is fastest or closest and 

15 download information from that site. 

B. Determine from the -protocol- field the protocol the printer 
requires. 
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20 c. checX the -protocoldate- field and the users platform to ascertain 

if the protocol required is present and up to date, step 32. if not, the 
user is asked if they wish to download the required protocol, if yes, the 
helper initiates a protocol download using IP in a similar manner to 
downloading the helper paragraph B. once the appropriate files for a 
protocol have been downloaded, the protocol is installed as appropriate 
to the users platform. 
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T>. Once satisfied that the correct protocol is installed and at the 
correct level, check if the printer driver is installed. For Microsoft 
platforms an API call can be made returning a list of installed printers 
Even if installed, the -driverdate- field needs to be checked to 
determine if the correct driver for the printer is available on the users 
machine, step 34. if not one is automatically downloaded from the nearest 
software repository as described in paragraph B above using IP 
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Once satisfied that the correct protocol and driver are available 
the helper installs a printer object on the users platform, step 36 In* 
the case of Windows -98, this is done with a further APi call 
ad^rinterO . 

P. Configure the printer object in accordance with requirements of the 
company/user, step 38. Company specific configuration information is held 
in the •a4fiie- field which points to a configuration file, in the 
present example, the file 43l795.cfg contains special configuration data. 
It is preferably downloaded with the packaged driver file, in this case 
IBI05.EXE. It is used to set specific settings within the print driver 
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rather than relying on the manufacturers defaults. For exantple, a company 
may decide that all ita users should use duplex printing to save on paper 
costs, the helper can do this using the data in this file to set the 
correct paper size, tray settings etc. 

5 

G. Finally, once installed the printer is preferably set as the 
default printer, step 40. 

It will be seen that there are a number of advantages to the 
10 present invention: 

A. It is web based and therefore can be made available to anyone on 
the internet, this could include digital TV. 

25 B. Users never have to worry about having the right level driver or 

which printer to set as a default* with a plethora of print objects on 
the desktop this is always a problem. Preferably, the helper uses a 
single reconfigurable object, always set as the default, which maXes for 
great ease of use. 

20 

C. the -alx file can be encrypted to provide for a greater level of 
corporate security should this be necessary. This is particularly useful, 
if a printer is to be password protected'. The .alx file of Table «l 
includes a •password" field, if this is populated, the helper knows to 
25 ask the user for a password before Installing the printer, without 

encryption, however, the user could simply save the .alx file and look at 
the password field to obtain the password.; and 

0. It does away with the need for FAX machines, which is the solution 
30 usually employed by mobile users without printing facilities - 

It will be seen that the invention is not limited to the NETBEUI or 
TCP/IP protocols mentioned above. Other protocols are, for example, IPP 
(internet Printing Protocol) which is a Java based printing protocol 

35 being jointly developed by a consortium of companies to deal with some of 

the problems the present invention overcomes. The invention can also 
operate with PSM (Printing Systems Manager) also called PSP (Printing 
Submit Format) or InfoPrint, an IBM developed printing protocol, which is 
In essence an IP based protocol that puts print Jobs into a certain 

40 format so that they can be received by an AIX print server. 

It will also be seen that printer objects can be divided according 
to category. Each category can preferably be linked to frOTi an index 
page, in a preferred embodiment, the index page contains a map, and 
45 printers are divided into geographical areas. Thus, a mobile user simply 

needs to connect to the internet, select the index page, select the 



geographicBl area in %Alch a retired printer Is located (this need not 
correspond with his actual location), select the printer froa the page 
associated with the geographical area which causes the helper to install 
the printer, and then print as normal. 

It Should also be seen that the .alx file for a printer need not be 
located on a remote web site. It is also possible for a iser to browser 
either through local drives, lam network drives or intranet sites to 
access a required .alx file. This of course removes much of the ease of 
use of the preferred embodiment, as ths user aay then need to acquire 
suitable passiiord access to a UN netwrk or to know more about the 
location of .alx files than is necessary. Nonetheless, the invention is 
applicable to aay helper operating with a printer configuration file 
accessed from a browser to configure a workstation to connect to a 
printer. 



The preferred eaibodiment has been described in terms of the helper 
component configuring the browser's workstation to enable the workstation 
to connect to a printer. It will be seen, however, that the helper may in 
some eases need to connunicate with and possibly configure a server 
controlling a printer to make said server receptive to print requests 
from the workstation and the tern enable should be interpreted to cover 
any combination of remote of local configuration required to enable the 
workstation to connect to the required printer. 
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Table #1 
(DATA] 

protocol=lP 
5 type»ZBH 4039 

ar9S»XPADDRESS»9 .180.145.227; QUEUE»PRT1 2 
os2drv»ZBMOTPS*iBM network Color Printer 
wlnl6drvsAD0BBPS*rBM NetvrorX color Printer 
win98drv»IBH Network Printer 17 
10 wlnntdrvsXBN Network color Printer 

password- 

helperdate»18/2/1999 

protocoldate°31/01/1998 

drlverdateoi2/10/1998 
15 os2drvdate=4/3/1999 

winl Sdrvda t e»23 /3 / 19 9 8 

wiA9 8drvdate«24/S/199 6 

Winn tdrvdate=12/2 /19 9 7 

6ite»9.180.145,227 
2 0 pass "pr tdrv 

nameeprtdrv 

[IBM Network Printer 17) 
drv£ile»IBM95.BXE 
25 d4file«'431795.CPG 
vers ion* 10 24 

drlvemamesIBM Network Printer 17 
environment "Windows 4.0 
data£ile°XBH43171,pPD 
30 drlverpatb<'AD0BEPS4 . DRV 

con£ igf ile"AiX)BEPS4 , DRV 
belpf ile«AD0BEPS4 .HLP 
inanitor«PostScrlpt Language Monitor 
de£aulttype»RAW 

35 eiielist»zaM43171.ppD,coll43xx.dll,lBM43171.DLL,adobeps4.drv,adobeps4.hlp 
« pscr ipt . ini , fonts .m£m, iconlib . dl X « psmon . dll 
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1. A printer connectivity coiqponent cooperable with a web browser to 
connect a worKatation to a printer, said cotqponent coapriaing: 

means instantiable to read a configuration file, con^priaing data 
defining a coimection to said printer, accessed fron the' browser; 

means, responsive to said configuration file data, to enable said 
worlcstatian to connect to said printer. 

2. A component as claimed in claim 1 wherein the camponent is one of a 
helper application or a browser plug -in. 

3. A component as claimed in claim 1 wherein said file comprises 
respective fields indicating said printer's location, a protocol for 
connecting to said printer at said location and a driver required for 
said printer, and said component coinpriBess 

means for checking if said workstation is configured to use. said 
protocol and said driver; and 



means for installing said protocol' and said driver. 

4. A component as claimed in claim 3 wherein said file further 
Includes fields Indicating said protocol and said printer driver dates 
and said camponent comprises! 

means for checking the dates of installed versions of said protocol 
and said driver and irtierein said means for installing is responsive to 
said protocol or said driver being out of date to Install a new version 
of said protocol or driver. 

5. A coBiponent as claimed in claim 3 wherein said file comprises one 
or more fields indicating one or more locations from which new versions 
of said protocol and said driver can be accessed and said component 
comprisest . 



means for connecting to the or each location to download said 
protocol and said driver. 

6. A component as claimed in claim 5 wherein said file further 
includes a field indicating a date for a helper and said components 
comprises ; 
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means for checking the dates of Installed version of said component 
and wherein said means for installing is responsive to said component 
being out of date to install a new version of said component. 

7. A component as claimed in claim 1 wherein said configuration file 
includes platform dependent information for each workstajtion platform 
that is to connect to said printer and said component. 

8. A web server including the printer connectivity component of 
claim Is one or more of said configuration file, each associated with a 
respective printer and one or more veb pages, each including one or more 
links to a respective configuration file. 

9. A web server as claimed in claim 6 wherein one of said web pages 
Includes a reference to said component. 

10. A web server as claimed in claim 6 wherein one of said web pages 
includes a map, portions of which are associated with respective web 
pages including links to said configuration files* 

11. A computer program product comprising computer program code stored 
on a computer readable storage medium for, when executed on a computer, 
connecting a workstation to a printer, the program code comprising a 
printer connectivity component according to claim 1. 

12. A method of coxuiecting a workstation running a web browser to a 
printer comprising the steps of: 

said browser, accessing a printer configuration file, said file 
comprising data defining a connection to said printer; 

said browser, responsive to receipt of said configuration file, 
instantiating a component associated with said configuration file type; 
and 

said component, responsive to said configuration file data, 
enabling said workstation to connect to said printer. 
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